/* Copyright 2012-2017 Jose Robson Mariano Alves This file is part of bgfinancas. This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This package is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see <http://www.gnu.org/licenses/>. */ package badernageral.bgfinancas.modelo; import badernageral.bgfinancas.biblioteca.utilitario.Lista; import badernageral.bgfinancas.biblioteca.contrato.Modelo; import badernageral.bgfinancas.biblioteca.banco.Coluna; import badernageral.bgfinancas.biblioteca.contrato.Categoria; import badernageral.bgfinancas.biblioteca.sistema.Janela; import badernageral.bgfinancas.biblioteca.tipo.Operacao; import badernageral.bgfinancas.biblioteca.utilitario.Erro; import java.math.BigDecimal; import java.sql.ResultSet; import java.sql.SQLException; import java.util.ArrayList; import java.util.List; import javafx.collections.FXCollections; import javafx.collections.ObservableList; import javafx.scene.control.ComboBox; public final class Conta extends Categoria<Conta> implements Modelo { private static final String MODULO = RAIZ+"/modulo/conta"; public static final String FXML = MODULO+"/Conta.fxml"; public static final String FXML_FORMULARIO = MODULO+"/ContaFormulario.fxml"; public static final String TABELA = "contas"; private final Coluna valor = new Coluna(TABELA, "valor"); private final Coluna ativada = new Coluna(TABELA, "ativada"); private final Coluna saldoTotal = new Coluna(TABELA, "saldo_total"); public Conta(){ this(null, null, null, null, null); } public Conta(String idCategoria, String nome, String valor, Object ativada, Object saldoTotal){ this.idCategoria = new Coluna(TABELA, "id_conta", idCategoria); this.nome = new Coluna(TABELA, "nome", nome); this.valor.setValor(valor); this.ativada.setValor(Lista.getSimNao(ativada)); this.saldoTotal.setValor(Lista.getPoupancaCredito(saldoTotal)); } @Override protected Conta instanciar(String idCategoria, String nome) { return new Conta(idCategoria, nome, null, null, null); } @Override protected Conta instanciar(ResultSet rs) throws SQLException{ return new Conta( rs.getString(idCategoria.getColuna()), rs.getString(nome.getColuna()), rs.getString(valor.getColuna()), rs.getString(ativada.getColuna()), rs.getString(saldoTotal.getColuna()) ); } @Override public boolean cadastrar(){ return this.insert(nome, valor, ativada, saldoTotal).commit(); } @Override public boolean alterar(){ return this.update(nome, valor, ativada, saldoTotal).where(idCategoria, "=").commit(); } private boolean alterarSaldo(){ return this.update(valor).where(idCategoria, "=").commit(); } @Override public boolean excluir() throws Erro{ ObservableList<Despesa> despesas = new Despesa().setIdConta(this).listar(); ObservableList<Receita> receitas = new Receita().setIdConta(this).listar(); ObservableList<Transferencia> transferencias_origem = new Transferencia().setIdContaDestino(this).listar(); ObservableList<Transferencia> transferencias_destino = new Transferencia().setIdContaOrigem(this).listar(); if(despesas.size()>0 || receitas.size()>0 || transferencias_origem.size()>0 || transferencias_destino.size()>0){ throw new Erro(); }else{ return this.delete(idCategoria, "=").commit(); } } @Override public Conta consultar() { try{ this.select(idCategoria, nome, valor, ativada, saldoTotal); if(idCategoria.getValor() != null){ this.where(idCategoria, "="); }else if(nome.getValor() != null){ this.where(nome, "="); } ResultSet rs = this.query(); if(rs != null && rs.next()){ return instanciar(rs); }else{ return null; } }catch(SQLException ex){ Janela.showException(ex); return null; } } @Override public ObservableList<Conta> listar(){ try{ this.select(idCategoria, nome, valor, ativada, saldoTotal); if(nome.getValor() != null){ this.where(nome, "LIKE"); }else if(ativada.getValor() != null){ this.where(ativada, "="); } this.orderByAsc(nome); ResultSet rs = this.query(); if(rs != null){ List<Conta> Linhas = new ArrayList<>(); while(rs.next()){ Linhas.add(instanciar(rs)); } ObservableList<Conta> Resultado = FXCollections.observableList(Linhas); return Resultado; }else{ return null; } }catch(SQLException ex){ Janela.showException(ex); return null; } } public void alterarSaldo(Operacao operacao, String id_conta, String valor){ idCategoria.setValor(id_conta); Conta c = consultar(); BigDecimal novoValor = c.getValor(); if(operacao==Operacao.INCREMENTAR){ novoValor = novoValor.add(new BigDecimal(valor)); }else{ novoValor = novoValor.subtract(new BigDecimal(valor)); } c.setValor(novoValor.toString()); c.alterarSaldo(); } @Override public void montarSelectCategoria(ComboBox<Categoria> combo){ try{ combo.getItems().clear(); combo.setPromptText(idioma.getMensagem("selecione")); ativada.setValor("1"); this.select(idCategoria, nome, valor, ativada, saldoTotal).where(ativada, "=").orderByAsc(nome); ResultSet rs = this.query(); if(rs != null){ while(rs.next()){ combo.getItems().add(instanciar(rs)); } } }catch(SQLException ex){ Janela.showException(ex); } } public BigDecimal getValor() { return new BigDecimal(valor.getValor()); } public String getAtivada() { return ativada.getValor(); } public String getSaldoTotal() { return saldoTotal.getValor(); } public void setValor(String valor) { this.valor.setValor(valor); } public Conta setAtivada(String ativada) { this.ativada.setValor(ativada); return getThis(); } @Override protected Conta getThis() { return this; } }